Authorization এবং Role-based Security

Microsoft Technologies - এন্টিটি ফ্রেমওয়র্ক (Entity Framework) Entity Framework এ Security Features |
195
195

Authorization হল নিরাপত্তার একটি গুরুত্বপূর্ণ অংশ যা ব্যবহৃত হয় ব্যবহারকারীদের অ্যাপ্লিকেশন বা সিস্টেমের বিভিন্ন অংশে অ্যাক্সেস নিয়ন্ত্রণ করতে। এটি নিশ্চিত করে যে, একটি ব্যবহারকারী কোন রিসোর্সে প্রবেশ করতে পারবে এবং কোন কাজ করতে পারবে, এবং কোন রিসোর্সে তাকে প্রবেশের অনুমতি নেই। Role-based Security হল একটি পদ্ধতি যা ব্যবহারকারীদের বিভিন্ন Roles প্রদান করে এবং সেই অনুযায়ী তাদের অ্যাক্সেস নিয়ন্ত্রণ করে।


Authorization কী এবং কেন এটি গুরুত্বপূর্ণ?

Authorization ব্যবহৃত হয় ব্যবহারকারী বা গ্রুপের জন্য একটি নির্দিষ্ট কাজ বা রিসোর্সে অ্যাক্সেসের অনুমতি প্রদান করার জন্য। এটি সাধারণত Authentication এর পরে চলে, যেখানে প্রথমে ব্যবহারকারীর পরিচয় যাচাই করা হয় এবং পরে তার অ্যাক্সেস অধিকার নির্ধারণ করা হয়।

Authorization নিশ্চিত করে যে:

  • একটি ব্যবহারকারী নির্দিষ্ট ডেটা বা কার্যক্রমে অ্যাক্সেস করার জন্য অনুমোদিত কিনা।
  • একজন ব্যবহারকারী একাধিক ডেটাবেস বা সিস্টেমের অংশের মধ্যে সীমাবদ্ধ নয়, তাকে শুধুমাত্র তার অনুমোদিত অংশে কাজ করার অনুমতি দেওয়া হয়।

Authorization সাধারনত Access Control Lists (ACLs) বা Claims-based Security এর মাধ্যমে পরিচালিত হয়।


Role-based Security কী?

Role-based Security বা Role-based Access Control (RBAC) একটি নিরাপত্তা মডেল যেখানে ব্যবহারকারীদের একটি নির্দিষ্ট Role বা ভূমিকা দেয়া হয় এবং সেই অনুযায়ী তাদের সিস্টেমের বা অ্যাপ্লিকেশনের অংশে অ্যাক্সেস অনুমোদিত হয়। এর মাধ্যমে সহজেই বড় সিস্টেম বা অ্যাপ্লিকেশনে ব্যবহারকারীদের অ্যাক্সেস নিয়ন্ত্রণ করা যায়।

যে ব্যবহারকারীদের এক ধরনের দায়িত্ব বা ভূমিকা (Role) থাকে, তাদের সেই অনুযায়ী permission বা অনুমতি প্রদান করা হয়। উদাহরণস্বরূপ:

  • Admin রোল: সম্পূর্ণ অ্যাক্সেস থাকে।
  • Manager রোল: কিছু সীমিত অ্যাক্সেস (যেমন, রিপোর্ট দেখা বা কিছু ডেটা আপডেট করা) থাকে।
  • User রোল: কেবলমাত্র নিজস্ব ডেটা দেখা এবং আপডেট করার অনুমতি থাকে।

RBAC এর উপকারিতা:

  1. নিরাপত্তা বৃদ্ধি: ব্যবহারকারীদের নির্দিষ্ট অনুমতি দেওয়া যায়, যাতে তারা শুধু তাদের প্রয়োজনীয় রিসোর্সেই কাজ করতে পারে।
  2. সহজ ব্যবস্থাপনা: যখন ব্যবহারকারীদের গ্রুপের মধ্যে অ্যাক্সেস নিয়ন্ত্রণ করতে হয়, তখন Role-based Security ব্যবস্থাপনা সহজ হয়।
  3. নির্দিষ্ট ক্ষমতা: ব্যবহারকারীকে তার কাজের জন্য প্রয়োজনীয় ক্ষমতা দেয়া হয়, যার ফলে সীমিত ক্ষমতায় কাজ করতে হয়।

ASP.NET Core তে Authorization এবং Role-based Security

ASP.NET Core তে Authorization এবং Role-based Security বাস্তবায়ন করা খুব সহজ। এর জন্য ASP.NET Core এর Identity Framework এবং Claims-based Authorization ব্যবহার করা হয়।


1. ASP.NET Core Identity Framework

ASP.NET Core Identity হল একটি পূর্ণাঙ্গ সিস্টেম যা ব্যবহারকারী পরিচালনা, লগইন, রেজিস্ট্রেশন, পাসওয়ার্ড পুনরুদ্ধার এবং Authorization পরিচালনা করে। এতে সহজেই Role-based Security বাস্তবায়ন করা যায়।

Identity Framework Setup Example:

public class ApplicationUser : IdentityUser
{
    // Custom properties (if any)
}

public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
    public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options) : base(options)
    {
    }
}

এখানে:

  • IdentityUser হল ASP.NET Core Identity এর প্রাক-নির্ধারিত ক্লাস যা ব্যবহারকারীদের জন্য প্রয়োজনীয় সকল তথ্য সংরক্ষণ করে।
  • ApplicationDbContext Identity এর ডেটাবেস কনটেক্সট। এটি ব্যবহারকারীদের লগইন, রেজিস্ট্রেশন ইত্যাদি পরিচালনা করে।

2. Role-based Authorization in ASP.NET Core

ASP.NET Core তে ব্যবহারকারীদের Role ভিত্তিক অ্যাক্সেস নিয়ন্ত্রণ করার জন্য [Authorize] অ্যাট্রিবিউট এবং RoleManager ব্যবহার করা হয়। RoleManager ব্যবহার করে Roles তৈরি এবং প্রয়োগ করা হয়।

Role Creation Example:

public class SeedData
{
    public static async Task Initialize(IServiceProvider serviceProvider, UserManager<ApplicationUser> userManager, RoleManager<IdentityRole> roleManager)
    {
        var roleNames = new[] { "Admin", "Manager", "User" };

        foreach (var roleName in roleNames)
        {
            var roleExist = await roleManager.RoleExistsAsync(roleName);
            if (!roleExist)
            {
                await roleManager.CreateAsync(new IdentityRole(roleName));
            }
        }

        // Create admin user
        var adminUser = await userManager.FindByEmailAsync("admin@example.com");
        if (adminUser == null)
        {
            adminUser = new ApplicationUser { UserName = "admin@example.com", Email = "admin@example.com" };
            await userManager.CreateAsync(adminUser, "Admin@123");
        }

        // Assign role to admin
        if (!await userManager.IsInRoleAsync(adminUser, "Admin"))
        {
            await userManager.AddToRoleAsync(adminUser, "Admin");
        }
    }
}

এখানে:

  • প্রথমে "Admin", "Manager", এবং "User" নামক রোলগুলো তৈরি করা হয়েছে।
  • পরে, একটি Admin ব্যবহারকারী তৈরি করা হয়েছে এবং তাকে Admin রোল প্রদান করা হয়েছে।

3. Authorization by Role

একটি কন্ট্রোলারের অ্যাকশন বা পৃষ্ঠা নির্দিষ্ট রোলের জন্য সীমাবদ্ধ করতে [Authorize] অ্যাট্রিবিউট ব্যবহার করা হয়।

Example (Role-based Authorization):

[Authorize(Roles = "Admin")]
public IActionResult AdminDashboard()
{
    return View();
}

[Authorize(Roles = "Manager,Admin")]
public IActionResult ManagerDashboard()
{
    return View();
}

[Authorize(Roles = "User")]
public IActionResult UserDashboard()
{
    return View();
}

এখানে:

  • AdminDashboard কেবলমাত্র Admin রোলধারী ব্যবহারকারীদের জন্য অনুমোদিত।
  • ManagerDashboard Admin এবং Manager রোলধারী ব্যবহারকারীদের জন্য উন্মুক্ত।
  • UserDashboard কেবলমাত্র User রোলধারী ব্যবহারকারীদের জন্য।

Authorization এবং Role-based Security এর নিরাপত্তা সুবিধা

  1. বিশদ নিয়ন্ত্রণ: আপনি ব্যবহারকারীদের জন্য আরও সুক্ষ্ম অনুমতি নির্ধারণ করতে পারেন, যেটি সাধারণ permission সিস্টেমের তুলনায় বেশি কার্যকর।
  2. বিস্তারিত লগিং: রোল ভিত্তিক অ্যাক্সেস সিস্টেম ব্যবহার করে সহজেই অ্যাক্সেস লগ এবং অ্যাক্সেস ট্র্যাক করা সম্ভব।
  3. সুবিধাজনক ব্যবস্থাপনা: একাধিক ব্যবহারকারীর জন্য রোল নির্ধারণ করে, সহজে অ্যাক্সেস নিয়ন্ত্রণ করা যায়।
common.content_added_by
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion